МЕТОДИ ПОШУКУ У МАСИВАХ

Інформація про навчальний заклад

ВУЗ:
Національний технічний університет України Київський політехнічний інститут
Інститут:
Не вказано
Факультет:
ЗІ
Кафедра:
Не вказано

Інформація про роботу

Рік:
2022
Тип роботи:
Звіт до лабораторної роботи
Предмет:
Програмування складних алгоритмів

Частина тексту файла

НАЦІОНАЛЬНИЙ ТЕХНІЧНИЙ УНІВЕРСИТЕТ УКРАЇНИ “КИЇВСЬКИЙ ПОЛІТЕХНІЧНИЙ ІНСТИТУТ імені ІГОРЯ СІКОРСЬКОГО” ЗВІТ з лабораторної роботи №4 з навчальної дисципліни “Програмування складних алгоритмів” Тема: «МЕТОДИ ПОШУКУ У МАСИВАХ» Варіант 13 Київ 2022 Мета: Метою лабораторної роботи є отримання практичних навичок в бробці масивів, у пошуку елементів масивів різними методами. Дослідження і вивчення методів пошуку ключових елементів у масивах. Здійснення порівняння та аналізу ефективності використовуваних методів пошуку Теоретичні відомості Лінійний пошук з бар’єром. Ідея алгоритму: – у вихідний масив потрібно тимчасово включити шукане значення. – для одержання результату пошуку потрібно перевірити, чи дорівнює укане значення тому елементу масиву, на якому відбулось завершення роботи лгоритму. – навіть, якщо елемент у початковому масиві був відсутній, і зупинка була дійснена на включеному в масив зразкові, перевірка результату буде проведена для вихідного елементу масиву, який на той час замінить зразок пошуку. – після завершення пошуку потрібно повернути в кінець масиву початкове начення розміри масиву. Роль бар’єрного елементу виконує включений в масив зразок пошуку. Додаткові операції по установці і зняттю бар'єра окупаються спрощенням циклу, у якому витрачається основний час при пошуку. Особливо це позначиться при великих розмірах масиву. В загальному випадку час пошуку буде меншим, ніж у попередньому випадку. Звичайно у тому випадку, коли елементи масиву можуть повторюватись пошук не можна припиняти поки не перевірили всі елементи масиву до кінця. Тоді для практичної реалізації алгоритму потрібно застосувати цикл з лічильником, а пошук проводити до кінця масиву, це дасть можливість знайти всі відповідні елементи. У такому випадку кількість перевірок дорівнює – N. Алгоритм Рабіна-Карпа – це алгоритм пошуку рядка, який шукає шаблон, обто підрядок, у тексті використовуючи хешування. Ідея алгоритму: Є рядок A, довжина якого дорівнює m, потрібно знайти зразок X довжиною n. Виріжемо "віконечко" розміром n і перевіряємо по вхідному рядку. Шукаємо слово в "віконечку" із заданим зразком. Порівнювати по буквах довго. Замість цього фіксуємо деяку числову функцію на словах довжиною n, тоді завдання зведеться до порівняння чисел, що, безсумнівно, швидше. Якщо значення цієї функції на слові в "віконечку" і на зразку різні, то збігу немає. Тільки якщо значення однакові, необхідно перевіряти послідовно збіг по буквах. Завдання до лабороторної роботи: 1. Знайти заданий елемент у невпорядкованому масиві (не менше 10х10) задопомогою методу пошуку з бар’єром. 2. Знайти заданий елемент у впорядкованому масиві (не менше 10х10) згідноваріантів за таким принципом. / Рис. 1. Завдання 13 варіанту. Результат роботи / Висновки: розроблено програму, що виконує пошук у невпорядкованому масиві випадоковиї чисел за допомогою методу лінійного пошуку з бар’єром, який має багато переваг у швидкості виконання на прикладах з великими розмірностями масивів. Також розроблено код, що виконує пошук підстроки з початкової строки та повертає індекс входу підстроки. Метод пошуку розроблено за алгоритмом Рабіна-Карпа. Програмний код public class Lr4 { public static void main(String[] args) { int side = 10; int[][] arr = generateArr(side); displayArr(arr); System.out.println("Введіть елемент, який треба шукати:"); Scanner scanner = new Scanner(System.in); int key = scanner.nextInt(); Point keyPos = null; for (int i = 0; i < arr.length; i++) { int index = searchWithBarrier(arr[i], key); if (index != -1) { keyPos = new Point(i+1, index+1); break; } } if (keyPos == null) System.out.println("Елемент " + key + " не знайдено"); else System.out.println("Елемент " + key + " знайдено у рядку: " + keyPos.x + ", стовпчи...
Антиботан аватар за замовчуванням

11.06.2023 07:06

Коментарі

Ви не можете залишити коментар. Для цього, будь ласка, увійдіть або зареєструйтесь.

Завантаження файлу

Якщо Ви маєте на своєму комп'ютері файли, пов'язані з навчанням( розрахункові, лабораторні, практичні, контрольні роботи та інше...), і Вам не шкода ними поділитись - то скористайтесь формою для завантаження файлу, попередньо заархівувавши все в архів .rar або .zip розміром до 100мб, і до нього невдовзі отримають доступ студенти всієї України! Ви отримаєте грошову винагороду в кінці місяця, якщо станете одним з трьох переможців!
Стань активним учасником руху antibotan!
Поділись актуальною інформацією,
і отримай привілеї у користуванні архівом! Детальніше

Оголошення від адміністратора

Антиботан аватар за замовчуванням

пропонує роботу

Admin

26.02.2019 12:38

Привіт усім учасникам нашого порталу! Хороші новини - з‘явилась можливість кожному заробити на своїх знаннях та вміннях. Тепер Ви можете продавати свої роботи на сайті заробляючи кошти, рейтинг і довіру користувачів. Потрібно завантажити роботу, вказати ціну і додати один інформативний скріншот з деякими частинами виконаних завдань. Навіть одна якісна і всім необхідна робота може продатися сотні разів. «Головою заробляти» продуктивніше ніж руками! :-)

Новини